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DYNAMICALLY ADJUSTING A PROCESSOR'S OPERATIONAL 
PARAMETERS ACCORDING TO ITS ENVIRONMENT 

Technical Field! 

This invention relates to portable computers and performance and thermal issues associated therewith. 
Background Art 

A conventional notebook computer has power and thermal constraints that cause it to operate at 
performance levels below an equivalent desktop computer. When using a battery as a power source, a 
conventional notebook computer often employs techniques to conserve battery life, which can reduce 
performance levels. In addition, the conventional notebook computer has a small, densely packed system 
construction that limits its ability to safely dissipate the heat generated by computer operation. Therefore 
conventional notebook computers generally use less power than their desktop counterparts, which adversely 
affects performance. 

Many power saving techniques have been introduced to try and mitigate the limitations caused by 
thermal and battery power constraints. The frequency of operation (clock frequency) of the processor and its 
operating voltage determines its power consumption. Since power consumption and therefore heat generation 
are roughly proportional to the processor's frequency of operation, scaling down the processor's frequency 
below desktop performance levels has been a common method of staying within notebook computer power 
limitations. 

A common power management technique called "throttling" prevents the processor from over heating 
by temporarily stopping processor operations by stopping processor clocks. Throttling is an industry standard 
method of reducing the effective frequency of processor operation and correspondingly reducing processor 
power consumption by using a clock control signal (e.g. the processor's STPCLK# input) to modulate the duty 
cycle of processor operation. A temperature sensor placed on or near the processor initiates throttling when 
needed. Throttling continuously stops and starts processor operation according to a predefined duty cycle with 
a period of a few milliseconds. The reduction in the effective speed of the processor reduces power dissipation 
and thus the processor's temperature. 

Applications like word processors typically leave the processor idle much of the time. As a result, the 
typical processor power consumption when running word processing applications can be as much as 30-50% 
below the maximum. That idle time can be exploited by the computer system to achieve additional power 
savings by putting the processor to sleep temporarily. 

For example, in a word processing application, a processor will do a brief burst of work after each 
letter is typed, then its operation is stopped until the next keystroke. Additionally, peripheral devices may be 
turned off to obtain move power savings. For example, the notebook's hard drive may be suspended after a 
certain period of inactivity until it is needed again. If the system detects another period of inactivity, e.g., a 
few minutes, the display may be turned off. Such techniques are useful in conserving battery power and in the 
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define the status of the subsystems and the sleep states, such as suspend-to-RAM and suspend-to-disk. The 
four global Gx states are shown in Fig. 1 A. 

When the computer is operating in the GO state, the CPU can have the four computing states shown in 
Fig* IB. Note that in a given platform, it may not be necessary to support all the CPU states. For example, CI 
and C2 for some systems may offer similar power dissipation and latencies for restoring operation. Therefore, 
the designer may choose to implement only one of these states. Also, different systems may have different 
implementations of a particular CPU state. Unlike the sleep states, in which various parts of the computer 
system may be powered down, all systems remain powered up in the computing states. 

When the computer is in the Gl state (sleeping), the system will be in one of the four sleep states 
shown in Fig. 1C. Like the Cx states, some sleep states may not exhibit significantly different behavior for a 
given design. Therefore, it may be reasonable to not implement one or more of the states in a particular 
system. 

As can be seen, the ACPI environment provides a number of mechanisms to deal with thermal and 
power issues. However, the desire for notebook performance to approach that of desktop computers requires 
the processor to run faster and dissipate more heat However, the notebook still must run in the mobile 
environment limited by power and thermal constraints. Therefore, it would be desirable if the notebook could 
adapt readily to its environment in order to provide the appropriate level of performance given the operating 
environment. While ACPI and current power management techniques provide some level of monitoring and 
control based on a notebook computer's operating environment, there is a need to provide improved power 
management techniques that more effectively responds to the environment in which the notebook computer is 
being used. Further, it would be desirable to dynamically adjust to the demands of the various environments 
without significantly impacting the user. 

DISCLOSURE OF INVENTION 

Accordingly, a notebook or similar computing device monitors system environment such as 
availability of external power sources (AC adapter, auto adapter or other external power source), attachment 
and/or activation of auxiliary cooling devices, and a profile, which may be user definable, for choosing 
performance criteria during battery operation. When changes take place for any of these factors, system level 
software assigns appropriate operating parameters or "run states" for the processor of the computing device. 

Each run state has different limitations on available power and power dissipation and the situation can 
change while the notebook is in use. Ideally, in each run state the processor takes full advantage of the 
available power and the power dissipation ceiling. In order to change the run state, the system changes the 
processor's core clock frequency and core voltage. Since processor frequency determines a minimum required 
voltage for operation, the voltage and frequency of operation for the processor core are changed at the same 
time. As core frequency is changed, the core voltage is also changed. 
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Fig. 1 A is a tabJe showing the four global Gx states. 

Fig. IB is a table showing the four computing states. 

Fig. 1C is a table showing various sleep states. 
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Fig. 3A summarizes the various run modes illustrated in Fig. 2. 

Fig. 3B provides exemplary performance parameters for various run modes. 

Fig. 4 provides a graph illustrating relationships between voltage, frequency and power. 
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Fig. 6 illustrates one implementation of a clock control circuit in the CPU. 

Fig. 7 illustrates generally the operation to control voltage and frequency according to one 
embodiment of the present invention. 

Fig. 8 illustrates the use of power on suspend CPU context lost (POSCCL) in one embodiment of the 
invention, 

Fig. 9A shows timing charts illustrating a POSCCL suspend and the corresponding resume operation. 
Fig. 9B is a table describing the signals shown in Fig. 9A. 

Fig. 10 illustrates use of a programmable logic device to effect run mode changes. 

Fig. 1 1 illustrates an implementation of a logic device from Fig. 10. 

Fig. 12 is a timing diagram illustrating the operation of logic device of Fig. 1 1 . 

Fig. 13 shows a run mode control register utilized in one south bridge implementation to effect run 
mode changes. 

Fig. 14 shows a high level block diagram of a south bridge implementation to provide both jumper 
inputs and register inputs for voltage and frequency control. 

Fig. 15 illustrates a flow chart implementing run mode changes in a south bridge integrated circuit 

Fig. 16 illustrates an exemplary docking station which may be used with a notebook computer 
incorporating the various run modes described herein. 

The use of the same reference symbols in different drawings indicates similar or identical items. 

MOTO/Sl FOR CARRYING OUT THE INVENTIO N 

A notebook computer or other portable computing device according to one embodiment of the present 
invention, dynamically adapts the operation of the notebook computer and its processor to changes in its 
environment to provide improved performance and battery life. To determine those changes, the notebook 
computer monitors such things as application or removal of external power sources (AC adapter, auto adapter 
or other external power source), changes in thermal environment (attachment of auxiliary cooling devices 
embedded in AC adapters, port replicators, docking stations or other attachable devices with cooling 
capabilities or cooling capability within a notebook that can be used because of the availability of external 
power), and changes in a user definable profile for battery operation (e.g. maximizing performance or battery 
life). 



WO 01/35200 

PCT/US00/17460 



6- 



30 



35 



When changes are detected for any of tho«. or 
system software. S to exit a PP^cation programs or 

to Ihe CPU to be the ,e.„ po !si b le „ Zl ^ "* " """^ <*• v.to S «p^ded 

f„ , 8ivra ft^, of CPU ^ ratiM " i "' d " ,OT ' * ~w 

v.^ of tfc M „ No ,~" "^'^ *~ - *• ™'» powc «e „ 

* *. v., ase ^ w j^^r 

*»• s*-* off cbip. *' m ree, °" """W™* Ugh voto, e ,„ 

*«fOTi»gtoFi s .2,,a, reim< . hinejssto . 



WO OX/35200 



- 7- 



PCT/USOO/17460 



performance of a desktop computer, run mode 3(11) provides maximum system performance (clock frequency 
and heat dissipation) when, e.g., docked in a docking station providing auxiliary power and auxiliary cooling. 
That may require that the docking station incorporate a sophisticated cooling system to force air through the 
processor heat sink or to otherwise conduct heat out of and away from the processor with, e.g., a heat pipe or 
heat plate. The heat pipe may also be used to conduct heat into the docking station where a heat sink and fans 
are used to dissipate the heat 

If the system becomes undocked, the system can enter either run mode 1 (13) or run mode 0(15). 
When operating from the battery (run mode 0 or 1 ), the user can choose between power conservation and 
performance; Run mode 1 is a performance mode that maintains processor speed that may be as high as run 
mode 2 and require active cooling. That high level of performance reduces battery life as a result of increased 
power dissipation by the processor and by the need to run a cooling device such as a fan to aid in heat 
dispersion. In the performance/battery operation mode, the performance is limited by the limits of active 
cooling. 

Alternatively in run mode 0, battery saver mode, battery life is emphasized over performance. In the 
maximum battery life mode, run mode 0, the limits of passive cooling provide a performance ceiling. That 
ceiling may be higher than actual performance due to the desire to extend battery life by reducing power 
consumption by the processor even below the performance ceiling. The ability to operate without active 
cooling in the Battery Saver Mode (Run Mode 0) is dependent on low power dissipation in the Stop 
Clock/Grant state in which processor core clocks are stopped. Otherwise power will have to be expended for 
active cooling. 

In addition, at least one mode of operation may be provided that is between the two extremes of run 
mode 1 and run mode 0. That t4 between the two extremes" mode provides active cooling but with a lower 
performance target that results in active cooling needing to switch on less frequently. That operational mode 
benefits from lower processor power consumption and less frequent consumption of power by the cooling fan. 
Additional battery modes may be provided which have even more granularity between the performance 
emphasized in run mode 1 and the battery life emphasized in run mode 0. In one implementation, the user 
may specify through a control panel applet the various battery operation modes in a manner similar to a user 
selecting the time delay before the display or hard drive sleeps. 

Run mode 2(17) provides external power (e.g., from an AC adapter) while the notebook computer is 
undocked. Run mode 2 provides for maximum performance limited by thermal considerations. The lack of 
auxiliary cooling may limit run mode 2 performance below run mode 1 . However, if the notebook has an 
active cooling device, it can be utilized continually in run mode 2 without concerns about power consumption. 
That allows the CPU to operate at a higher frequency than in run mode 1 . 

Each run mode is intended to provide the maximum performance within the constraints of the 
available cooling mechanism and battery life requirements. Fig. 3A summarizes the various run modes 
illustrated in Fig. 2 along with total dissipated power (TOP). It is possible for various environments to prompt 
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or warn the user about operating. For example, a DVD movie playback program can check the run mode when 
launched. ACPI maintains tables indicating the performance level. If operating in run mode 0 (battery saving 
mode), a warning message can be generated that the full frame rate of playback may not be possible until the 
user selects one of toe other operating modes. 

The computer system should provide a small latency between run modes. The user may be able to 
tolerate a latency of up to, e.g., 1 second but preferably the latency should not be noticed by the , 



: user. 



Fig. 3B provides a table of exemplary performance parameters for various run modes. For example 
in run mode 0, CPU voltage is 1.6 volts and the CPU frequency is 200 MHz. In contrast, run mode 3 provides 
400 MHz operation at 2.2 volts. 
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Referring to Fig. 4, the graph shows a comparison of power reduction for a notebook that reduces its 
average frequency of operation through "throttling" which was described previously. The left vertical axis is 
m volts. The right vertical axis is in Watts. Line 41 illustrates the voltage required as a function of frequency 
for a typ.cal notebook processor. The middle line 43 shows power as a function of frequency and illustrates 
the power savings available from reducing frequency. As can be seen the power savings is generally linear 
Note that the power savings from reducing frequency is equivalent to power savings provided from throttling 
Lane 45 shows power as a function of both voltage and frequency and illustrates the power savings available 
from reducing both voltage and frequency. Note that throttling may be used in combination with the reduction 
of both voltage and frequency to further reduce the effective speed or power dissipation of the processor In a 
typ.cal notebook system, the additional power savings at 200 MHz is equivalent to at least 45 minutes of 
20 battery life. 

Run mode changes are controlled by state machine logic that is triggered by software but once 
tnggered the state machine can perform its operations while the processor is sleeping. The run mode logic can 
be bu .It into the power management features of a south bridge integrated circuit or implemented with a 
separate logic device that augments standard south bridge power management or in any other location suitable 
in the computer system. The software required to make run mode changes can be triggered by SMI or SCI 
features built into standard south bridges. Tne software required can leverage existing routines for placing the 
processor m a sleep or suspend mode and then resuming operations. 

In one embodiment as described further herein, a processor changes its internal bus-multiplier state 
and mamtains or recovers the state of its internal registers through chipset control. That feature allows for 
multiple modes of frequency operation without powering-off the system or manually reconfiguring the bus 
frequency (BF) pins as described further herein. 

Because sleep and suspend states require the processor operation to be stopped, i, is impossible for 
system software to control all sleep, suspend and recover operations. To overcome this problem, state 
machmes are provided in the input/output integrated circuit (known as the south bridge) to control the final 
stages of sleep and suspend operations and the resume operation. Many notebook computers use state 
machines within the south bridge integrated circuit to provide common power management features . One 
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such integrated circuit is the 82371 AB PC1-TO-ISA/IDE XCELERATOR (PIIX4) available from Intel Coip. 
The power management features contained therein reduce power consumption to extend battery life and 
control heat generation and dissipation to safely operate the processor. While some use a separate 
microcontroller for the task, most notebook PCs rely on the south bridge to provide the hardware for thermal 
and power management. The south bridge is one chip of a chipset that also includes a north bridge. The north 
bridge provides a memory controller function as well as a bridge function between the Peripheral Component 
Interconnect (PCI) bus and the host bus connected to the processor. The south bridge also interfaces to the 
PCI bus (which functions as a major input/output bus in the computer system) and provides a variety of 
functions including providing an interface with legacy devices on the ISA bus (or integrated into the south 
bridge), providing an interface to various other input/output buses and/or functions (e.g. Universal Serial Bus 
(USB)) and also providing various power management related functions. South bridge chips from various 
manufacturers have typically utilized the registers, timers and state machine definitions used in the Intel PIIX4 
south bridge. PIIX4 compatibility in current south bridge chips can be extended to support mobile operational 
modes described herein. 

In an exemplary embodiment illustrated in Fig. 5, voltage regulator 501 supplies core voltage 502 
(commonly referred to in the x86 processor environment as Vcca) to processor (CPU) 503. In the embodiment 
illustrated, south bridge 505 controls the voltage level that is supplied to CPU 503 by supplying voltage 
control signals VID[4:0] to voltage regulator 501. In order to control processor frequency, in one typical 
implementation such as that used for the AMD-K6® processor, three bus frequency input pins (BF[2:0]) are 
used to determine the internal operating frequency of the processor. South bridge 505 controls the operating 
frequency of CPU 503 by supplying the CPU with BF (bus frequency) signals BF[2:0]. The bus clock signal 
506, which is supplied to CPU 503 from clock generator 507, is multiplied internally by the CPU by a ratio 
determined by the value of the three bus frequency pins. The multiplication factor ranges, in one 
implementation from 2.5 times the bus clock to 6.0 times the bus clock. Other multiplication factors are 
possible according to the specific system implementation. 

Fig. 6 illustrates one implementation of the clock control circuit in the CPU. Frequency divider circuit 
61 receives the BF pins, which are sampled during assertion of a processor reset signal (CPURST). The 
sampled values are applied to a phase locked loop (PLL) clock multiplier/synthesizer circuit for a long enough 
period of time for the PLL to stabilize. The values of the BF pins are latched into frequency divider 61 on the 
falling edge of the CPURST signal. The reset pulse is sufficiently long to ensure that the clock multiplier 
circuitry is stable. The bus clock 63 is provided to the phase (frequency) detector 64 which provides a control 
voltage 65 to voltage controlled oscillator (VCO) 67. The VCO supplies the core logic of the CPU with a 
clock having a frequency determined by the bus clock frequency multiplied by a value determined from the BF 
pins. Gating logic 68 may be used to gate off the CPU core clocks when the appropriate gating signal 69 is 
asserted to stop core clocks. 

Additional BF pins may be useful to provide greater range in clock multiplier values to ensure that 
battery life mode (run mode 0) is adequately supported, i.e., the processor can run slow enough, as faster and 
faster processors are provided. 
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registers and latches or other circuit nodes in time sensitive paths, since otherwise unpredictable behavior may 
result. In current X86 architectures that is achieved by first asserting the STPCLK# signal to cause the CPU to 
stop its internal clock distribution. On receipt of STPCLKtf, the CPU completes the currently active 
instruction and asserts a "Stop Grant" indication. Once the "Stop Grant** is received, clocks may be stopped at 
clock generator 507 using enable signal 509. Conveniendy, the framework of ACPI provides a number of 
suspend and sleep operations which are supported in the south bridge and which may be modified to 
implement suspend processor operation in the context required here. 

The flow chart in Fig. 7 illustrates generally the operation to control voltage and frequency according 
to one embodiment of the present invention. Assume that the processor is operating in a normal operational 
mode in 70 with the voltage regulator 501 receiving appropriate voltage control signals VTD[0:4] and 
frequency control circuitry receiving appropriate frequency control signals (e.g. the BF signals). The computer 
system detects a change in operating characteristics such as power source, thermal environment or user 
selected operating parameters in 71. In response to detecting that change, the system stops processor operation 
in 72 by stopping its clocks and determines a new frequency and corresponding voltage settings appropriate 
for the new run mode. That information may be saved in registers in the south bridge or in other suitable 
locations in the computer system. Updated voltage and frequency control signals are supplied to the 
appropriate voltage and frequency control circuit in 73 and 74 and then the processor resumes operation in 75. 

The resume operation is triggered from one of the last actions of the suspend operation. One of the 
steps in the resume operation contemplated in association with Fig. 7, is for the resume operation to issue a 
frequency control signal update indication (e.g., a reset (CPURST)) to the processor. That frequency control 
update or valid signal indicates to the processor that there is valid data on the BF pins that should be used for 
generation of core clocks. If a CPU reset is used for that purpose, that reset is applied only to the processor 
and not to those portions of the computer system not requiring a reset. 

In one implementation, the processor senses the values of the frequency control signals (on the BF 
pins) when a reset signal is asserted and latches in those values on the falling edge of reset (see Fig. 6). 
Alternatively, a signal other than reset may be asserted to indicate to the processor that new frequency control 
signal values are present. If the reset signal is used to indicate that new frequency control (BF) signals are 
available, the processor loses context on assertion of reset, e.g., values in the processor registers may be lost. 
Thus, processor context should be saved prior to issuing a reset or an application will not be able to resume 
where it left off. Once the reset is completed, the processor context can be restored from wherever it has been 
saved with the processor operating at the new frequency and voltage settings. It is desirable to minimize the 
latency of the resume operation and therefore desirable to restore the processor context as fast as possible. 

Sleep and suspend states require the processor operation to be stopped. Therefore, it is impossible for 
system software to directly control some management operations. To overcome this problem, state machines 
in the south bridge take control of the system to suspend processor operation and suspend other system 
devices. Once the system is in a sleep or suspend state, the south bridge monitors several possible events for 
waking the system. When an events occurs, another state machine sequences the system to resume operation. 
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suspend operation. For example, the suspend to disk resume latency is typically less than 30 seconds, suspend 
to RAM approximately one second and power on suspend with context maintained approximately 20 ms. 
Maintaining context obviously reduces resume latency. 

Table 1 



Bits 112:101 


Suspend Type 


000 


Soft Off or Suspend to Disk (STD) 


00 1 


Suspend to RAM (STR) 


0 1 0 


Powered On Suspend, Context Lost (POSCL) 


0 1 1 


Powered On Suspend, CPU Context Lost (POSCCL) 


1 00 


Powered On Suspend, Context Maintained (POS) 


1 0 1 


Working (Clock Throttling May Be Active) 


1 1 0 


Reserved 


1 1 1 


Reserved 



As previously discussed, asserting reset to notify the processor of a change in BF signal values to 
effect clock frequency changes associated with changes in run modes, causes the processor context to be lost. 
One of the suspend operations which restores CPU context is the Powered on Suspend, CPU Context Lost 
(POSCCL) shown above. That suspend operation may be utilized when a reset is used to latch in the new BF 
10 pin values as illustrated in Fig. 8. 

Referring to Fig. 8, which illustrates the use of POSCCL in one embodiment of the invention, once 
the new operational environment is detected, i.e., a new run mode is desired, the new voltage and frequency 
settings are loaded into appropriate registers in 801. Those registers may be in the south bridge or in 
additional logic, which embodiment is described further herein, or in any other suitable location in the 

15 computer system. Once those registers are loaded, the processor context is saved and the resume operation is 
set up in 803 by specifying a restart address. Saving processor context may include flushing the internal cache 
of the processor and saving the state of the processor to DRAM. The set up of the jump entails setting the 
start-up vector address (real mode) and setting the necessary flag byte so the BIOS will immediately branch to 
the restore routine after CPU reset instead of rebooting the system. X86 processors always begin execution in 

20 the address range F0OO:FFF0 after reset. In a conventional x86 personal computer system, the BIOS ROM 
exists at that address range. BIOS checks a flag byte in RAM to see whether BIOS should branch to execute 
special code, such as restore processor context or perform a cold boot. 

After processor context is saved, software then triggers the south bridge state machine that suspends 
the processor in 805 by reading a register within the south bridge. The final actions of the suspend state 

25 machine triggers new run mode logic which may be implemented as a state machine. The new run mode logic 
updates the voltage and frequency control signals provided respectively to the voltage regulator and the 
frequency control logic in the CPU with the new voltage and frequency control settings and then provides a 
wake-up indication to trigger the resume state machine in 809. Note that voltage being supplied to the core 
logic is changed while core clocks are off, which mitigates risk of adverse affects of the voltage change. 

30 Alternatively, or in addition, as described further herein, core voltage may be changed while a reset is being 
applied to the processor. Although it is not necessary for the processor to be reset when the core voltage is 
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many applications, the full range or precision of the voltage regulator is not needed and some control inputs to 
the regulator may be tied high or low. Thus, the approach herein provides flexibility by allowing varying 
numbers of voltage and frequency control signals to be used based on the needs of the particular system. 

Referring to Fig. 1 1, one implementation of programmable logic device 101 is shown in greater 
5 detail. In the implementation illustrated there are 13 inputs and 9 outputs and the design can be implemented 
in a standard programmable array logic (PAL) device. The signals originating from south bridge may be 
clocked by the real time clock (RTC) (32 kHz); therefore a high speed logic device is unnecessary. 

There are eight input flip-flops 1101 connected as a serial shift register which receive a shift signal 
1 102 and a data in signal 1 104 from south bridge 103. South bridge 103 uses one general purpose output 
10 (designated as GPO-X) as the shift signal supplied to PLD 101 and another general purpose output (designated 
as GPO-Y) as the data in signal to PLD 101. PLD 101 includes eight output flip-flops 1 103 receiving input 
signals from a selector circuit 1 105, which selects either one of the input flip-flops or one of the jumper 
settings (IBF[0:3] and IV[0:3]). On a power on reset the flip-flops are held in reset until Power Okay 
(PWROK) 1 107 is asserted. While PWROK 1 107 is asserted, south bridge 103 issues a reset to the processor. 

1 5 Note that the default values of the voltage and frequency control signals represented by the jumper 

settings should be reapplied to the frequency and voltage control circuits if a system reset is created either by 
pushing the reset button or by software or by any other mechanism. Therefore, the state of the GPO bit used to 
drive data in 1 104 must default to logic zero if that bit is also used as a select signal for select logic 1 105 as 
shown in the illustrative embodiment depicted. If data in 1 1 04 is zero for system reset, that assures that the 

20 default values from the jumpers settings are appropriately selected by select logic 1 1 05. In some 
implementations, only a few of the PIIX4-compatible south bridge bits have this property (e.g., 
GPO[27:28,30]) and therefore the GPO-X and GPO-Y bits are selected from among those bits. Using one of 
those bits insures that the start-up jumper settings will be communicated to the voltage regulator and the 
processor's BF-pins during reset in the implementation shown. Other implementations would be readily 

25 apparent to one of skill in the art. Using the data in signal 207 as a multiplexer select minimizes the number of 
GPO pins required, although additional GPO signal(s) from the south bridge could also be used to provide the 
multiplexer select signal. 

When the system initially powers up, the rising edge of the CPURST signal causes the default or 
startup voltage and frequency settings to be loaded into output registers 1 103 and thus be provided to voltage 
30 regulator 501 and CPU 503. Loading the output registers will immediately set the voltage regulator to the 
initial value. The default frequency settings will also be output. CPURST causes the processor to loads its 
BF-pin inputs and sets the initial bus clock multiplier for generating the CPU core clock. 

Once a need to transition to a new run mode is detected by the notebook system and prior to 
executing a suspend/resume sequence to change the processor voltage and bus clock multiplier, the GPO bits 
35 on the south bridge are used to load the new values into data input registers 1 101. Referring to Fig. 12, the 
setup for the transition sequence occurs in 121 when the shift signal 1 102 is used to shift in the new voltage 
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and frequency settings on data in signal line 1 104 into input register 1101. Once that setup is completed the 
suspend operation is executed which includes saving processor context and, as illustrated in Fig 12 asserting 
STPCLK# and SLP#. 8 ' a5SCTTU1 8 

As descrfced, the GPO bit 1 104 used to input data into the shift registers, also steers the multiplexer 
1 105. Leaving the bit high during the suspend/resume sequence steers the multiplexer to supply the output of 
the shift registers, instead of the jumpers, to the inputs of the output registers 1 103. The serial data is written 
to logic device writing to the appropriate GPIO ports. 

Once the core voltage and frequency have been changed in the input register 1 101, the south bridge is 
made to execute a POSCCL operation which causes the south bridge to supply a signal indicating that the 
suspend operation is at or near completion. As shown in Fig. , 2, that is the SLP# signal although other signals 
could also be used. That signal indicates the end of the suspend sequence and is provided as trigger (TG#) 
1 109 to PLD 101 . In mis particular implementation, TG# is active low. PLD 101 creates an even, to resume 
operation, i.e., wake up the processor by logically combining that trigger signal with data input 1 107 in gate 
1 1 1 1. That is used to gate SLP* through as the wake event (active low) to south bridge input GP1 1# that is 
sensed as a wake up event resulting in a standard POSCCL resume operation, which as previously described, 
* useful for setting new processor frequency multiplier because it cycles the processor reset. Thus, as shown 
m F,g. 12, the end of the suspend operation results in the wake event That in turn that causes the resume 
sequence illustrated in Fig. 12. Once the resume sequence is complete, the GPO signal 1 107 used as the data 
input is brought low. 

The assertion of CPURST during the resume sequence loads the values from the input registers 1 ,01 
mto output registers 1 103. The values in output registers 1 1 03 provide the new frequency multiplier settings 
and the core voltage settings for the processor and voltage regulator respectively. Thus, the new voltage 
settings are applied to the core logic of the processor while CPU reset is asserted. The new frequency 
mulupher ratio BF-pin settings are sampled by the CPU on the rising edge of CPURST and latched on the 
falhng edge of CPURST into the processor. The POSCCL resume allows time for resynchronizing the 
processor PLL. B 

Using the PLD allows an unmodified south bridge and processor to be used in a notebook system 
having the capability to transition between run modes. 

If it is desired to keep the run mode transition logic and software as simple as possible it is 
recommended that the bus clock frequency not be changed between 66 MHz and 1 00 MHz during the change 
Smce the BF settings are conventionally in * x steps (e.g. 2x, 2.5x, 3*. 3.5x, etc.) that limits the granularity of 
the processor clock frequency steps. If greater complexity is acceptable such changes can be implemented 
Changmg the frequency of the bus clock afreets the divider ratios used to create the Peripheral Component' 

^^(PajandAcceleratedGraphicsPortfAGPJcloclcs. It may be necessary to put memory into a 
sleep or power down when changing the clock ratios. 
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The implementation described herein utilizes a variable voltage regulator supply such as the National 
Semiconductor's LM4130, whose output voltage can be controlled by the chipset logic (including any external 
device). It is desirable for the voltage regulator to support at least four control bits and for the output voltage 
to be controllable in steps of 50mV (or smaller) covering a minimum range of from 1 .45 to 2.2 volts. A wider 
5 range may be desirable in some applications. The voltage regulator's control pins should be configured for 
default operation at the Mode 0 (battery saver) voltage level upon power-up. The chipset or other appropriate 
logic will then adjust the CPU voltage supply for the right run mode once the system is operational. 

SOUTH BRIBGE IMPLEMENTATION 

In order to provide an implementation that minimizes the number of components needed to change 
10 run modes as described herein, the south bridge can be modified to provide the logic necessary to transition 
between the various run modes rather than utilize an external logic device. A high level implementation of 
such a system is illustrated in Fig. 5. 

One approach to the south bridge implementation is to incorporate the logic contained in the PLD into 
the south bridge. However, the logic can be simplified since the various signals needed to interface the south 
15 bridge to the PLD can be eliminated. In addition, the use of the data input signal as the multiplexer signal 

could be eliminated. In fact, the input registers would preferably be loaded in parallel, rather than serially thus 
eliminating the need for a shift signal. Once the determination is made that a new run mode is required, a 
register in the south bridge is provided with appropriate voltage and frequency settings. 

In one implementation, the south bridge defines a new sleep type in the power management control 
20 register (see Table 1 above) using one of the combinations of bits [12:10] not presently used (e.g., 1 10). Those 
bits are variously referred to as either sleep type or suspend type. When the sleep enable bit (or suspend 
enable) is set to one and the sleep type bits are 110, then the system causes a transition in the notebook run 
modes. 

Referring to Fig. 13, run mode control register 130 provides the control information necessary to 
25 transition to a new run mode. The two bit operating mode field 131 is a status field that identifies the current 
run mode as either high performance (00), AC power (01), battery performance (10) or battery save mode (1 1). 
Additional run modes would require additional bits. The five bit core voltage field 132 defines the control bits 
for the new core voltage and the four bit CPU clock frequency control bits 133 define the CPU core frequency. 
As discussed herein, the clock control in the CPU may be implemented as a frequency multiplier of the bus 
30 clock. The reset control bit 134 defines whether or not a reset is provided to the CPU during the run mode 
transition. In one embodiment, when the reset control bit is 1, the CPU is reset on a run mode transition and 
when the reset control bit is 0, the CPU is not reset. If a reset is provided to the CPU in order to change the 
operating core frequency, then it is necessary to save processor context prior to the reset and to provide a 
resume operation that restores processor context after the reset signal is deasserted as was discussed with 
35 relation to the POSCCL sequence. 
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In other embodiments, the processor may have an input signal, separate from reset, that tells the 
processor when to latch in the clock frequency control bits. In that case, the latch mode CMD bit 135 is 
asserted. In that implementation, the south bridge provides, in addition to the frequency control bits (BF[0-2]) 
a frequency latch control signal (CMD) 515 (see Fig. 5) indicating to the CPU when to latch in the new 
frequency control bits. When the frequency latch control signal CMD 515 is asserted, BF pin setting may be 
acqu^ed on the assertion of the CMD 515 signal and latched on the falling edge of CMD 515. Other 
implementations to acquire the BF pin settings based on the latch control signal CMD, are of course possible 
Use of the latch control signal CMD 515 signal provides the advantage of transitioning to a new run mode 
without having to provide a reset which means that processor context is not lost. Thus, the transition is 
significantly less time consuming than the POSCCL suspend and resume operation. 

If the CPU reset signal is not used to indicate a frequency change, once the need to change run modes 
.s detected, software loads up the appropriate values in register 130 and stops the processor clocks. The 
clocks can be stopped on the processor using the STPCLK* signal as described previously. The new voltage 
and frequency control bits are output by the south bridge and the frequency control latch signal CMD 5 15 is 
asserted to mdicate that updated frequency control signals are available. The CPU samples the frequency 
control bits (BF puis) on the assertion of the latch control signal CMD 515 and latches in the new value on 
deassemon of the signal. Hardware in the south bridge maintains the latch control signal CMD 515 asserted 
for a sufficient length of time for the processor PLL to stabilize. Once the processor PLL is stabilized the 
south bndge hardware deasserts the STPCLK* signal and the processor resumes operation without the 
apphcation or user knowing about the run mode transition. The time to make the transition is less man, e g 
100 usee. " s " 



If reset is used to indicate a change in frequency, to avoid requiring changes to the processor a 
sequence similar to POSCCL illustrated in Fig. 9A may be used, with new control signals for voltage 'and 
frequency being provided between the latter part of the power on suspend (POS) sequence and the assertion of 
25 reset at 91 in Fig. 9A. 

The transition sequence from one run mode to another is initiated when an interrupt (e g SCI) is 
generated because of an operating mode even,. The event may be because the notebook computer is plugged 
mto or removed from a docking station, a port replicator or any other device than can remove large amount of 
thermal energy from the notebook; or when AC power is supplied or removed or when the battery is running 
30 low or any other event that should result in a change in the operating mode. 

The system management software, once the event is detected programs the operating mode control 
regmer 130 with the new core voltage and the new clock frequency control bits. The software then sets the 
sleep type bits to 1 10 as well as the sleep enable bit. The reading of special register LVL3 in south bridge 505 
starts the hardware state machine that performs the POSCCL sequence. The use of operating mode control 
re gl ster 130 may be advantageously employed with a south bridge only implementation and also with the PLD 
implementation previously described. 
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As an alternative to starting the change in run mode sequence by reading the LVL3 register, e.g., in a 
non-ACPI environment, writing (or reading) register 130 may be used as a trigger to start the control logic to 
implement the run mode change. Such a trigger may be used when the run mode change utilizes either the 
latch control signal CMD or the reset signal. In such a case, saving processor context would have to be 
5 completed before writing the register if a reset is utilized. If latch control signal CMD 515 is used, then that 
signal may be strobed, e.g., for one PCI clock, to indicate that the BIF signals are valid after register 130 is 
written. 

Referring again to Fig. 5, note that the south bridge still needs to ensure that the default value from 
the jumper settings 51 1 are provided to CPU 503 and the voltage regulator 501 . Referring to Fig. 14, that can 

1 0 be accomplished by providing, in a similar fashion to the PLD implementation, a multiplexer 141 that selects 
between the values in the control register 130 and jumper settings 511 according to select signal 142 supplied 
from control logic 144. Control logic 144 also contains the necessary suspend and resume state machines to 
implement the suspend and resume sequences illustrated, e.g., in Fig. 9A. Multiplexer 141 supplies output 
register 143 with values from jumper settings 51 1 which selects the default jumper settings in response to reset 

1 5 (e.g. a power on reset or other hard or soft reset). In addition, output register 143 is loaded after clocks are 
stopped and before supplying either a reset or CMD signal to load in new frequency settings or on the rising 
edge of reset of CMD assuming the falling edge causes a new frequency setting to be latched. 

Referring again to Fig. 13, control bit 136 defines whether or not the clock generator 507 is disabled 
or not during the run mode transition. Along with using the STPCLK# signal from the south bridge to disable 

20 the core CPU clocks, it is also possible to disable the clocks supplied to the CPU at clock generator 507 (as in 
POSCCL). The clock frequency control bits are then updated, and the clocks are turned back on at clock 
generator 507. Note that clock generator 507 may be integrated with other system components. It is desirable 
to have a clock generator whose outputs can be enabled by the south bridge's GPO control bits. The clock 
generator may have multiple PLL cells to support the various clock frequencies desired in any particular 

25 design, e.g., supporting the CPU at 100MHz or 66MHz, serial devices at 24KHz and 48KHz, and PCI devices 
at 3 3 MHz. 

Referring to Fig. 1 5, the flow chart illustrates the overall operation of the south bridge incorporating 
hardware to cause run mode changes. When an event is detected that results in a run mode change, such as an 
additional power source becoming available as described previously herein, software sets the required values 

30 for register 130 in 1501. In 1503, a determination is made as to whether or not reset control bit 134 is set in 

register 130. If so, then it is necessary to save processor context in 1504. That determines the exact sleep type 
that will be used by the south bridge. If the reset control bit 134 is not being used, that presumes that the latch 
command bit 135 is set and the step of saving processor context 1504 may be skipped Of course, only one bit 
needs to be used to indicate whether to use a reset or latch command signal. If accessing register 130 is used 

35 as a trigger to start a change in run mode, then context may need to be saved prior to such an access. Once 
processor context is saved in 1504 or if a reset is not being used, then state machine in south bridge can take 
over to perform following the steps to affect the run mode change. 



10 



15 



35 



WO 01/35200 

PCT/USOO/17460 

-20- 

ln 1505, the software executes a read of register LVL3 which starts a state machine sequence to effect 
the run mode change. In 1507, south bridge asserts STPCLK#. The state machine or other appropriate 
hardware and/or software waits for Stop Grant speciaJ bus cycle to be received which is an indication from the 
processor that it has turned off its internal core clocks. Note that the Stop Grant acknowledgement can be 
performed without monitoring of the CPU bus cycles by simply waiting a predetermined time which is more 
than the maximum time that could be taken to reach the Stop Grant state by the processor. 

In any case, once Stop Grant is acknowledged or the predetermined time limit is reached and it is 
assumed that Stop Grant state exists in the processor, it is determined if the stop clock bit 136 in control 
renter 130 is set. If the bit is set, then in 1513, the clock output to the CPU from clock generator 507 is 
turn ed off using the stop clock line (enable 509). Then in 15 15, new voltage and frequency control settings are 
apphed to the voltage regulator and the BF pins, respectively. In 1 5 17, it is determined whether the stop clock 
b,t (enable 509) is asserted. If so, in 1519, clock generator 507 is enabled to output the clock to the CPU and 
sufficient time is provided for the PLL to stabilize. In 1521, it is determined whether reset is being used to 
latch in the updated frequency control values. If so, then in 1 523, CPU reset is strobed to latch in the new 
frequency control bits. If reset has not been used, then the CMD signal 515 is strobed by the south bridge to 
cause the processor to latch in the new frequency without a reset. In 1527, the STPCLK* signal is deasserted 
That causes the CPU to resume supplying CPU core clock, The processor men resumes executing 1529 
Note thatif context was lost because reset was used, context is restored at tins point. That is accomplished 
under software control and no longer under hardware (e.g. state machine) control. 

Use of register 1 30 provides an embodiment in which the use of either reset or the latch control signal 
CMD 1S selectable, and turning off the clocks external to the processor is also selectable. In other 
embodiments, the south bridge (or other suitable integrated circuit) may not provide options. In other words 
» other embodiments, reset may always be used or the latch control command signal may always be used ' 
Further, the change run mode sequence may always turn off clocks externa, to the processor (as well as 
25 internally) or may always leave such clocks running. 

If the notebook PC uses both a 66 MHz and 1 00 MHz bus Cock frequency, the clock generator may 
have multmle PLL cells to be able to slew the CPU Cock input while maintaining other system required 
frequencies constant. The clock generator would be able to slew the CPU frequency across the desired range 
while keeping the rate of change in the CPU clock frequency within the jitter specifications of the CPU to 
prevent the clock multiplier circuitry within the processor from loosing lock 

THERMAL. WfA^ A ^ iMFrj 

Adjusting processor operating frequency and voltages optimizes power consumption and heat 
ge^ration and dissipation according to environment. In addition thermal management capability is required 
ACPI has two built-in schemes for thermal management, one passive and one active. The passive scheme ' 
rel.es on throtding down the processor to generate less heat while the active scheme uses a cooling device like 
a fan to remove hea, from the processor and system. A suitable thermal sensor measures the processor 
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temperature for passive and active schemes. The thermal design is based upon one or more thermal zones. For 
each zone, up to three thermal thresholds can be defined: 

There are two methodologies used today for thermal monitoring: a total system monitoring approach 
and a CPU-only monitoring. The total board monitoring philosophy provides a means of measuring all 
voltages (e.g., CPU core, CPU I/O, 3.3 V, 5 V 12 V, -12V -5), fan rotation speed, temperature of the CPU, and 
temperature of the board. Devices like the National LM78 may be used for this system monitoring approach. 
The CPU-only monitoring methodology can use the National LM75. The LM78 has an open collector output 
that is used to create an interrupt when the processor's temperature is above acceptable limits or when the 
temperature has changed by a certain amount. The System Management Bus (SMBus) may be used to 
program the over-temperature and temperature hysterisis values within the device. The SM Bus is a slow 2 bit 
serial bus that is used for communicating with monitoring devices like thermal sensors, chassis intrusion alert 
sensors and to provide fan speed control. Conventional south bridges have an SMBus interface so system 
software can talk to (setup and control) and read from (accept data from) such devices. The National LM77 
device has separate outputs to indicate over temperature or if temperature is above or below certain set points, 
which provides added reliability. If ACPI should fail to respond to the set point interrupt, the output indicating 
over-temperature can shutdown the system through hardware. 

ACPI maintains temperature set-points that are compared with the processor temperature. When the 
temperature exceeds the set-points, action is taken to reduce heat dissipation by the processor (passive method) 
or to expel the heat from the system (active method). The necessary registers and interface are generally 
20 contained in the PIIX4 south bridges. Most new south bridges are PIIX4 compatible. That helps reduce the 
effort necessary to adapt ACPI BIOS and operating system code for different company's chipsets. 

ACPI maintains set-points for processor thermal management. One is a fail safe set-point that will 
initiate a shutdown if the processor becomes too hot. Other set-points are associated with ACPI's "Active" 
and "Passive" cooling methods. Either or both methods can be incorporated into a notebook design 
25 incorporating the run modes described herein. 

In active cooling mode, ACPI rums on and off a cooling device based on temperature reports 
generated by a sensor placed on the processor heat sink or directly on the processor. When the temperature 
sensor senses a change in temperature (usually 5 degrees) it reports a new temperature to ACPI's thermal 
management. If the temperature is above a limit provided in an ACPI table, the cooling device is switched on. 
30 When the temperature sensor reports a drop in temperature that places the temperature below another table 
value, the cooling device is switched off. 

Note that these thresholds are programmable, and software is allowed to dynamically adjust the 
thresholds for optimum results. For example, when the active cooling threshold is crossed, the system 
software may start the system fan at a low speed, and reprogram the active cooling threshold at a higher 
35 temperature. If the system temperature continues to rise, it will eventually cross the new active cooling 
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threshold. In response, the fan speed can be increased, and if appropriate, the active cooling threshold can be 
set again at an even higher point. 

Generally, the cooling device is a miniature fan placed on or near the processor's heat sink. Running 
the fan circulates air from outside the notebook PC's case to cool the processor more than can be done by 
5 conduction and convection alone. Hie active cooling system may also be more sophisticated. When docked, 
an external fan in the port replicator or docking station can circulate more air. Other technologies that may be 
used include heat pipes, large thermal dissipation plates or refrigeration devices like the Peltier junction 
devices that have been used to cool desktop processors in the past. 

Mobile systems may use different active cooling device and temperature set points in the ACPI tables 
10 for each mode of operation (AC/battery and docked/undocked). Since active devices consume power 

themselves, it is recommended that these devices receive somewhat limited use in Run Mode 0, the battery life 
mode. Active cooling is a good solution when the system is running from an external power source such as 
AC-line adapter, car adapter or airplane adapter. 



15 



In passive cooling mode, ACPI power management dynamically reduces or increases the "speed" of 
the processor as necessary to maintain the processor operating temperature at a safe level. Obviously, 
"throttling" down the processor reduces performance, but even operating at somewhat reduced speeds', today's 
processors can provide adequate performance for running applications such as word processing. IT* throttling 
method used in most notebooks, directly supported by ACPI and PIIX4-compatible south bridges reduces the 
average processor speed by alternately starting and stopping the processor using the STPCLK# (stop clock) 
20 input of the processor. 

Most throttling implementations use three bit granularity. The duty cycle ranges from 12.5% to 100% 
in 12.5% steps. (Note that zero is not an acceptable value.) When temperature rises to an upper limit 
throttling is initiated at a level determined by an ACPI table value until the temperature falls below a lower 
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The stopping and starting of the processor is not noticeable to the user. The reason is that the 
frequency at which the start/stop action takes place is faster than a person can perceive. PIDM-compatible 
chipsets use the real time clock to drive a three bit counter that determines the duty cycle. 

Mobile systems operating in the extended battery life mode (Run Mode 0) should use clock throttling 
if necessary, to reduce heat generation. Mobile systems should have sufficient passive cooling when operating 
in Run Mode 0 with a room temperature of 25 degrees C that throttling is rarely needed. In elevated 
temperature environments, the processor can be throttled down more frequently. 

In order for a notebook PC to achieve desktop performance levels when docked, it requires additional 
thermal assistance from e.g., the docking station (or other solutions providing additional cooling capability and 
external power). The additional power dissipated through such solutions allows for a higher CPU power 
budget, thus permitting the processor to operate at desktop power and performance levels. 
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Rcfeiring to Fig. 16, a docking station solution with the notebook is illustrated. Fig. 16 shows an 
exemplary system that uses a Peltier device 1 63 in the docking station 162 to cool probe 165 that inserts into 
the back of the notebook computer 161 when the notebook system is docked in docking station 162. Probe 
165 makes contact with the processor's heat sink and conducts heat away. The probe 165 is cooled by the 
5 Peltier device 1 63 which requires several watts of power available from the docking station's AC operated 
power supply. 

Other options are available such as heat pipe technology. Heat pipes are generally made of tubes with 
water or other coolant under low pressure. When one end is heated by the processor, the coolant absorbs heat 
when it vaporizes. The vapor moves to the other end of the pipe where it is cooled by a heat sink. The vapor 
1 0 condenses as it cools and is moved by capillary action through a wick back to the starting point. Heat pipes 
can be made many different ways and can be connected to large surfaces like a metal case to dissipate heat 
Thus, notebook docking station solutions may include fans, heat sinks, and heat pipes to conduct heat away 
from the notebook computer when docked to allow for increased performance desired in run mode 3. 

Note that if thermal conduction is used, no user accessible part may rise above 50° C. No commonly 
1 5 contacted area should be uncomfortable to touch. Note also that while forced air from the docking station may 
increase processor cooling, it may also be noisy and cause a dust problem. 

The mechanical and electrical design should support the necessary sensing so the notebook computer 
can detect when the computer is being docked, is currently docked and when it is being undocked, when 
auxiliary power and/or auxiliary cooling is available and or when user defined operational states have been 

20 modified. In addition the notebook PC should detect when AC power is first applied, when AC power is 

present, and when AC power has been removed. The design should support detecting all standard notebook 
states such as power and reset buttons, when primary battery is present, the remaining capacity of battery (i.e. 
Smart Battery), the battery charging state, whether a secondary battery is present in an option bay, the 
remaining capacity of that battery, and that battery charging state. It should detect charging states include fast 

25 charge, trickle charge, battery fault (e.g., shorted), and not charging. It should detect when suspend button (or 
key combination) is pressed to suspend or wake the system, when the cover is closed or opened (e.g. option to 
suspend and wake or just to shutdown backlight). 

The system should also sense processor case temperature and at least two set points for temperature 
"alarms" (one for turning on a cooling device like a fan when the temperature is near the safe upper limit for 
30 operation, and one for immediate protective action when the temperature reaches a critical upper limit for 

preventing damage to the processor), If a fan is used for auxiliary cooling, confirmation that the fan is running 
is provided (it is desirable that the speed of the fan can be sensed). The sensing capability described above is 
known in the art and is not further described herein. 

As described herein, a notebook computer dynamically adapts to its environment to provide improved 
35 power and thermal management and optimizes its performance for its environment. Note that the description 
of the invention set forth herein is illustrative, and is not intended to limit the scope of the invention as set 
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forth in the following claims. For instance, while this invention has been described with relation to a class of 
mobne computers referred to herein as notebooks (which may also be referred to as laptops or portable 
computers), the teachings herein may also be utilized in other portable computing devices such as personal 
drgrtal assents, (PDAs) which are handheld devices that typically combine computing, te.ephone/fax, and 
network features or in other smal. form factor computing and/or communication equipment where such run 
modes may prove useful. Other variations and modifications of the embodiments disclosed herein may be 

ZZTTTn dCSCriPti ° n " ^ ^ With ° Ut ^ fr ° m *° SC0PC ^ ^tion as 

set forth in the following claims. 
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1 A method of controlling the power consumption of an integrated circuit in an electronic 

system, comprising: 

operating the integrated circuit at a first voltage and at a first frequency; 

detecting a change in at least one of a plurality of operating characteristics in the electronic system; 
in response to detecting the change, stopping clocks running on at least a substantial portion of the 
integrated circuit; 

supplying updated frequency control information to clock control logic in response to the change; and 
restarting the clocks to operate the integrated circuit at a second clock frequency corresponding to the 
updated frequency control information. 

2. The method as recited in claim 1 further comprising: 

supplying updated voltage control information to a voltage control circuit in response to the change; 
and 

operating the integrated circuit at a second voltage corresponding to the updated voltage control 
information. 

j 5 3 . The method as recited in claim 2 wherein the clock control logic is disposed on the 

integrated circuit and at least some clock signals are active on the integrated circuit while the clocks are 
stopped on the substantial portion of the integrated circuit and wherein clocks are stopped on the substantial 
portion of the integrated circuit according to a clock control signal supplied to the integrated circuit 

4. The method as recited in claim 2 wherein the frequency control information is provided as 
20 clock multiplier information to clock multiplier logic on the integrated circuit. 

5. The method as recited in claim in any of claims 1 through 4 wherein the integrated circuit is 
a processor and wherein the electronic system is a notebook computer system. 

6. The method as recited in any of claim 1 through 4 wherein the operating characteristics 
include a power source characteristic and a thermal environment. 

25 7. The method as recited in any of claims 1 through 4 wherein the operating characteristics 

include user selected operating parameters. 

8. The method as recited in claim 6 wherein the power source characteristic includes the 
presence of external power and wherein the thermal environment includes the availability of auxiliary cooling. 
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9. The method as recited in any of claims 1 through 4 further comprising saving processor 
context prior to stopping the clocks and restoring the processor context after restarting the clocks. 

1 0. A computer system comprising: 

an integrated circuit including a first logic portion, the first logic portion coupled to receive a first 
5 clock and a first voltage; 

a programmable voltage regulator circuit supplying a variable voltage level for the first voltage 

according to voltage control signals provided to the voltage regulator circuit- and 
a clock control circuit operable to generate the first clock at a frequency determined according to 
frequency control signals; and 
1 0 a control circuit coupled to receive an indication of a change in at least one of a plurality of operating 

characteristics in the computer system, the control circuit responsive to the change in 
operating characteristics to provide the voltage control signals and the frequency control 
signals indicating a new voltage value for the first voltage and a new frequency for the first 
clock, the new voltage value and the new frequency corresponding to the change in the 
15 operating characteristics. 

1 1. The computer system as recited in claim 10 wherein the operating characteristics include 
presence of external power and availability of auxiliary cooling and include user selected operating parameters 
selecting between a battery performance mode and a battery save mode for the computer system. 

12. The computer system as recited in claim 10 wherein the control circuit is disposed on a 
second integrated circuit and the second integrated circuit is coupled to supply a clock stop signal to the 
^grated circuit , me clock stop Slgna , bejng ^ ^ ^ ^ ^ ^ ^ 

the clock stop signal causing the first clock to be stopped on the integrated circuit and wherein the clock stop 
signal ,s deasserted after signals indicative of new voltage and frequency control signals have been provided to 
the voltage regulator and the frequency control logic, respectively. 
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□ BLURRED OR ILLEGIBLE TEXT OR DRAWING 

□ SKEWED/SLANTED IMAGES 

□ COLOR OR BLACK AND WHITE PHOTOGRAPHS 

□ GRAY SCALE DOCUMENTS 



□ REFERENCE(S) OR EXHIBIT(S) SUBMITTED ARE POOR QUALITY 

□ OTHER: 

IMAGES ARE BEST AVAILABLE COPY. 
As rescanning these documents will not correct the image 
problems checked, please do not report these problems to 
the IFW Image Problem Mailbox. 
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LINES OR MARKS ON ORIGINAL DOCUMENT 



